草庐IT

华为云DLI Flink作业生产环境推荐配置指导

全部标签

ruby-on-rails - 将 Heroku 环境变量传输到 Docker 实例

我在Heroku上构建了一个必须在Docker容器内运行的RoR应用程序。为此,我使用officialDockerfile.因为它在Heroku中很常见,所以我需要一些附加组件才能使这个应用程序完全运行。在生产中,变量DATABASE_URL在我的应用程序中可用。但是,如果我尝试其他一些使用环境变量(在我的例子中是Mailtrap)的加载项,变量不会在运行时复制到实例中。所以我的问题很简单:如何让docker实例在Heroku上执行时知道环境变量?您可能会问,我已经知道我们可以在docker-compose.yml中指定一个environment指令。我想避免这种情况,以便能够通过项目

ruby - 如何定义要从模块化 sinatra 应用程序的配置 block 中调用的方法?

我有一个Sinatra应用程序,归结起来,基本上是这样的:classMyApp不幸的是,这不起作用。我得到undefinedmethodread_config_fileforMyApp:Class(NoMethodError)read_config_file中的逻辑非常重要,因此我不想在两者中重复。如何定义可以从我的两个配置block调用的方法?还是我只是以完全错误的方式解决了这个问题? 最佳答案 configureblock似乎是在读取文件时执行的。您只需将方法的定义移到配置block之前,并将其转换为类方法:classMyApp

ruby-on-rails - Websocket-rails 不适用于 Nginx 和 Unicorn 的生产环境

我有带有gemwebsocket-rails0.7的Rails3.2应用程序。在开发机上,一切正常在生产环境中,我使用Nginx/1.6作为代理服务器,Unicorn作为http服务器。Thin用于独立模式(在https://github.com/websocket-rails/websocket-rails/wiki/Standalone-Server-Mode之后)。nginx配置:location/websocket{proxy_passhttp://localhost:3001/websocket;proxy_http_version1.1;proxy_set_headerUp

ruby-on-rails - 为开发/测试和生产指定相同的 gem 两次,但路径不同

有时您会制作特定于项目的gem。这有助于将一些“责任”从主Rails应用程序中抽象出来并转移到一个更加模块化的地方。gem将位于您应用程序的此处:gem'example_gem',path:'./example_gem'你捆绑,一切都很好。现在,您gitinitgem并将其存储在github上它自己的repo中。您尝试这样做以使其对开发人员友好:group:development,:testdogem'example_gem',path:'./example_gem'endgroup:productiondogem'example_gem',github:'company/exampl

ruby-on-rails - 如何将自定义 delayed_job 作业与 ActiveJob 一起使用?

我正在使用DelayedJob,我想更新我的Rails4.2应用程序以使用ActiveJob。问题是我有一堆看起来像这样的自定义作业:AssetDeleteJob=Struct.new(:user_id,:params)dodefperform#codeend#moremethodsn'stuffend然后在某处的Controller中,作业使用以下语法排队:@asset_delete_job=AssetDeleteJob.new(current_admin_user.id,params)Delayed::Job.enqueue@asset_delete_job我想找到ActiveJo

ruby-on-rails - rake spec 不使用 rails 环境

我正在尝试在刚刚升级到Rails2.3.2的Rails项目中使用rspec。我在应用程序中安装了rspec1.2.6和rspec-rails1.2.6作为插件。我的问题是规范无法访问我的应用程序类或任何Rails标准库。首先,我必须使用来自RAILS_ROOT的完整路径来指定我想要测试的模型类,但现在当它加载类时,我得到以下信息/app/models/person.rb:1:uninitializedconstantActiveRecord(NameError)from./spec/models/person_spec.rb:1:in`require'from./spec/models

ruby-on-rails - rails3 中 cron 作业的解决方案

我尝试每天在我的Rails应用程序中自动记录一些数据。我想知道是否有人知道一个好的解决方案?我找到了https://github.com/javan/whenever,但我想确保在选择之前了解所有选项。谢谢!艾略特 最佳答案 我真的很喜欢whenever-这是一个很棒的Gem,我已经在生产中使用了它。关于它还有一个很好的Railscasts插曲:http://railscasts.com/episodes/164-cron-in-ruby 关于ruby-on-rails-rails3中c

ruby-on-rails - "Private"Rake 任务与 Rails 环境

我知道我可以使用以下命令调用子任务列表并让每个子任务都利用我项目的Rails环境:task:main_task=>[:sub_task1,:sub_task2]doendtask:sub_task1=>:environmentdoModel1.some_class_methodendtask:sub_task2=>:environmentdoModel2.some_class_methodend我的问题是:main_task中是否有任何方法可以传递:environment,这样我就不必在每个子任务中显式地放置它?有没有办法让子任务被认为是“私有(private)的”?也就是说,我不希望

ruby - 如何在特定队列中推送作业并使用 sidekiq 限制工作人员数量?

我知道我们可以做到:sidekiq_optionsqueue:"Foo"但在这种情况下,Worker只分配给一个队列:“Foo”。我需要在特定队列中分配作业(而不是worker)。使用Resque很容易:Resque.enqueue_to(queue_name,my_job)另外,为了并发问题,我需要限制每个队列的Worker数量为1。我该怎么做? 最佳答案 您可能会使用https://github.com/brainopia/sidekiq-limit_fetch然后:Sidekiq::Client.push({'class'=>

ruby-on-rails - Unicorn.rb 配置取决于环境

我在config/unicorn.rb中有一行看起来像这样:working_directory"/SomePath/Web\Development/Rails/learning"但是在生产环境中,需要不同的路径。我想尽可能多地保留源代码控制(还没有放弃任何东西)。有没有办法根据环境设置working_directory? 最佳答案 您尝试如何访问RAILS_ENV或RACK_ENV?它应该通过“ENV”就像...ENV['RAILS_ENV']……或者……ENV['RACK_ENV']当您将“-E”标志传递给unicorn时,一个或